<template>
  <div class="ace-container">
    <!-- 官方文档中使用id，这里禁止使用，在后期打包后容易出现问题，使用 ref 或者 DOM 就行 -->
    <div :ref="id" class="ace-editor" @contextmenu="stopMenu" />
  </div>
</template>

<script>
import ace from "ace-builds";
import config from "@/config.json";
// const config = require('./src/config.json')
/* 启用此行后webpack打包回生成很多动态加载的js文件，不便于部署，故禁用！！
     特别提示：禁用此行后，需要调用ace.config.set('basePath', 'path...')指定动态js加载URL！！
   */
// import 'ace-builds/webpack-resolver'

// import 'ace-builds/src-min-noconflict/theme-monokai' // 默认设置的主题
import "ace-builds/src-min-noconflict/theme-sqlserver"; // 新设主题
import "ace-builds/src-min-noconflict/mode-javascript"; // 默认设置的语言模式
import "ace-builds/src-min-noconflict/mode-json"; //
import "ace-builds/src-min-noconflict/mode-css"; //
import "ace-builds/src-min-noconflict/ext-language_tools";
// ace.config.set(
//   "basePath",
//   "https://ks3-cn-beijing.ksyun.com/vform2021/ace-mini"
// );
export default {
  name: "CodeEditor",
  props: {
    id: {
      type: String,
      default: "ace",
    },
    value: {
      type: String,
      required: true,
    },
    readonly: {
      type: Boolean,
      default: false,
    },
    mode: {
      type: String,
      default: "javascript",
    },
    maxLines: {
      type: Number,
      default: 30,
    },
    userWorker: {
      // 是否开启语法检查，默认开启
      type: Boolean,
      default: true,
    },
  },
  data() {
    return {
      aceEditor: null,
      themePath: "ace/theme/sqlserver", // 不导入 webpack-resolver，该模块路径会报错
      modePath: "ace/mode/javascript", // 同上
      codeValue: this.value,
    };
  },
  watch: {
    //
  },
  mounted() {
    // ace.config.set('basePath', 'https://ks3-cn-beijing.ksyun.com/vform2021/ace')
    ace.config.set("basePath", config.base + "/js");
    this.addAutoCompletion(ace); // 添加自定义代码提示！！

    this.aceEditor = ace.edit(this.$refs[this.id], {
      maxLines: this.maxLines, // 最大行数，超过会自动出现滚动条
      minLines: 5, // 最小行数，还未到最大行数时，编辑器会自动伸缩大小
      fontSize: 12, // 编辑器内字体大小
      theme: this.themePath, // 默认设置的主题
      mode: this.modePath, // 默认设置的语言模式
      tabSize: 2, // 制表符设置为2个空格大小
      readOnly: this.readonly,
      useWorker: false,
      highlightActiveLine: true,
      value: this.codeValue,
    });

    this.aceEditor.setOptions({
      enableBasicAutocompletion: true,
      enableSnippets: true, // 设置代码片段提示
      enableLiveAutocompletion: true, // 设置自动提示
    });

    if (this.mode === "json") {
      this.setJsonMode();
    } else if (this.mode === "css") {
      this.setCssMode();
    }

    if (!this.userWorker) {
      this.aceEditor.getSession().setUseWorker(false);
    }

    // 编辑时同步数据
    this.aceEditor.getSession().on("change", () => {
      // this.$emit('update:value', this.aceEditor.getValue())  // 触发更新事件, 实现.sync双向绑定！！
      this.$emit("input", this.aceEditor.getValue());
    });
    // console.log(this.aceEditor.insert);
  },
  methods: {
    stopMenu(e) {
      e.preventDefault();
      this.$emit("onMenuCall", e);
    },
    addAutoCompletion(ace) {
      const acData = [
        {
          meta: "VForm API",
          caption: "getWidgetRef",
          value: "getWidgetRef()",
          score: 1,
        },
        {
          meta: "VForm API",
          caption: "getFormRef",
          value: "getFormRef()",
          score: 1,
        },
        // TODO: 待补充！！
      ];
      const langTools = ace.require("ace/ext/language_tools");
      langTools.addCompleter({
        getCompletions: function (editor, session, pos, prefix, callback) {
          if (prefix.length === 0) {
            return callback(null, []);
          } else {
            return callback(null, acData);
          }
        },
      });
    },

    setJsonMode() {
      this.aceEditor.getSession().setMode("ace/mode/json");
    },

    setCssMode() {
      this.aceEditor.getSession().setMode("ace/mode/css");
    },

    getEditorAnnotations() {
      return this.aceEditor.getSession().getAnnotations();
    },
  },
};
</script>

<style lang="scss" scoped>
.ace-editor {
  min-height: 300px;
}
</style>
